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What is claimed is: 




1. A multiprocessor computer system comprising: 

a first processor segment having a first microprocessor with a first internal cache, 
the c(3tatents of the first internal cache being unknown externally to the first processor 
segmept; 

a second processor segment having a second microprocessor with a second 
intemal\cache, the contents of the second intemal cache being unknown externally to the 
second i^ocessor segment; 
10 m^n memory; 

a ffirst interprocessor bus for coupling the first and second processor segments and 
the main memory; 

a sebond interprocessor bus for coupling the first and second processor segments 
and the main memory; 

15 a crossbar switch for switching between the first interprocessor processor bus and 

the second iimerprocessor processor bus; 

the fii^t processor segment further comprising: 
an external cache memory; 

la memory controller for causing the storage of data within the external 
20 cache memoryAthe data stored in the external cache memory corresponding to data in the 
first intemal caqhe; 

almemory identifier for identifying whether the data in the external cache 
memory is up to tiate relative to the memory in the first intemal cache; and 

a qata director for directing data requested by the second processor 
25 segment from thepnore up to date of the extemal cache memory and the first intemal 
cache. 
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2. The multiplrocessor computer system as defined by claim 1 wherein the first 
microprocessor indludes an associated invalidate flag that when set, invalidates data in 
the first intemal caihe. 
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3. Tlhe multiprocessor computer system as defined by claim 2 wherein the memory 
controUenincludes a determiner that determines if data within the first internal cache has 
been modiried by the first microprocessor, the data director directing modified data to the 
second processor segment. 

4. A mekhod for maintaining coherent data in a multiprocessor system having a 
plurality of processors coupled to main memory, where each processor has an internal 
cache which is externally imreadable outside the processor, the method comprising: 

requesttng data associated with a memory location in main memory; 

determining if an external cache coupled to an application specific integrated 
circuit associated with a second processor contains a reference to the requested data; 

performing a snoop cycle on the second processor if the external cache has a 
reference to the requested data; and 

determinipg if the requested data has been modified in the second processor. 

5. A method\for maintaining coherent data according to claim 4 further comprising: 
sending tq the requesting processor from the second processor the requested data 

if the second processor has modified the requested data. 



20 6, A method fqr maintaining coherent data according to claim 4, further comprising 
the step of: 

recalling froA main memory the data associated with a memory location in main 
memory if theextemal cache fails to have a reference to the requested data. 
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7. A method for maintaining coherent data in a multiprocessor system having a 
plurality of processors forming a segment, the processors connected together by a 
processor bus and the segment connected together by a system bus which is coupled to 
main memory, where each processor has an internal cache which is externally unreadable 
outside the processor, the method comprising: 



placing a request 
memory location in main 



from a processor in a first segment for data associated with a 
memory on the system bus; 
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detirmining if an external cache coupled to any application specific integrated 
circuit associated with a second segment contains a reference to the requested data; and 

performing a snoop cycle on the processor bus of the second segment if the 
second segment has a reference to the requested data. 
5 1 

8. A method according to claim 7, further comprising: 
deterqiining if the requested data has been modified. 

9. A metttod according to claim 8, further comprising: 
10 sending the requested data to the requesting processor from a processor in the 

second segment if the snoop cycle returns a signal indicating the processor of the second 
segment has mopified the requested data. 

10. A method according to claim 7, further comprising the step of: 
15 recalling from main memory the data associated with a memory location in main 

memory if all of me application specific integrated circuits associated with a segment fail 
to have a reference to the requested data. 



11. A multiprobessor computer system comprising: 
20 a first processor segment having a first microprocessor with a first intemal cache, 

the contents of the first intemal cache being unknown externally to the first processor 
segment; 

a second processor segment having a second microprocessor with a second 
intemal cache, the cqfitents of the second intemal cache being unknown externally to the 
25 second processor segHpent; 
main memory; 

a system bus for coupling the first, processor segment, the second processor 
segment, and main me naory; 

the first proces 5or segment further comprising: 
30 an extemal cac le memory; 
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memory, 



a memory controller for storing address information within the external cache 



le address information associated with data signals entering and exiting the 



first processor segment. 

5 12. Thi system according to claim 11, wherein the first processor segment further 
includes a processor bus and the second processor segment further includes a processor 
bus. 

13. Thekystem according to claim 1 1 , further comprising: 
10 a sedond extemal cache memory; and 

a sedond memory controller for storing address information within the second 
extemal cacHe memory, the address information associated with data signals entering and 
exiting the second processor segment. 



15 14. The syfetem according to claim 13, wherein the memory controller connects the 
system bus to the bus of the first processor segment and the second memory controller 
connects the sjstem bus to the bus of the second processor segment. 
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the first internal 



The multiprocessor computer system as defined by claim 11, wherein the first 
20 microprocessor [includes an associated invalidate flag that when set, invalidates data in 

cache. 



16. The multiprocessor computer system as defined by claim 15, wherein the memory 
controller includes a determiner that determines if data within the first internal cache has 
25 been modified by^ the first processor. 



